S&H Form: PTO/SB/05 (12/97) 



UTILITY 
PATENT APPLICATION 
TRANSMITTAL 

(Only for new nonprovisional applications under 37 CFR 1.53(b)) 


Attorney Docket No. 826.1 539/JDH 


First Named Inventor or Application Identifier: 1^v§S ~ 
Satoru CHIKUMA, et al. ^-fA^^S 


Express Mail Label No. ^ ^^^^O 




APPLICATION ELEMENTS 

See MPEP chapter GOO concerning utility patent 
application contents. 


ADDRESS TO: Assistant Commissioner for Patents 
Box Patent Application 
Washington, DC 20231 



1 . [X] Fee Transmittal Form 



2. [X] Specification, Claims & Abstract [ Total Pages: J83_ ] 

3. [X] Drawing(s) (35 USC 1 13) [ Total Sheets: _35_ ] 

4. [X] Oath or Declaration [ Total Pages: _4_ ] 

a. [X] Newly executed (original or copy) 

b. [ ] Copy from a prior application (37 CFR 1.63(d)) (for continuation/divisional with Box 17 completed) 
i. [ ] DELETION OF INVENTOR(S) 

Signed statement attached deleting inventor(s) named in the prior application, 
see 37 CFR 1.63(d)(2) and 1.33(b). 

5. [ ] Incorporation by Reference (usable if Box 4b is checked) 

The entire disclosure of the prior application, from which a copy of the oath or declaration is supplied under 
Box 4b, is considered as being part of the disclosure of the accompanying application and is hereby 
incorporated by reference therein. 

6. [ ] Microfiche Computer Program (Appendix) 

7. [ ] Nucleotide and/or Amino Acid Sequence Submission (if applicable, all necessary) 

a. [ ] Computer Readable Copy 

b. [ ] Paper Copy (identical to computer copy) 

c. [ ] Statement verifying identity of above copies 



ACCOMPANYING APPLICATION PARTS 



8. 


IX] 


Assignment Papers (cover sheet & document(s)) 


9. 


I 1 


37 CFR 3.73(b) Statement (when there is an assignee) I ] Power of Attorney 


10. 


[ 1 


English Translation Document (if applicable) 


11. 


[X] 


Information Disclosure Statement (IDS)/PT0-1449 [X] Copies of IDS Citations 


12. 


[] 


Preliminary Amendment 


13. 


[X] 


Return Receipt Postcard (MPEP 503) (Should be specifically itemized) 


14. 


[ ] 


Small Entity Statement(s) [ ] Statement filed in prior application, status still proper and desired. 


15. 


[X] 


Certified Copy of Priority Document(s) (if foreign priority is claimed) 


16. 


[ ] 


Other: 



17. If a CONTINUING APPLICATION, check appropriate box and supply the requisite information: 
[ ] Continuation [ ] Divisional [ ] Continuation-in-part (CIP) of prior application No: / 



18. CORRESPONDENCE ADDRESS 



STAAS & HALSEY 

Attn: James D. Halsey, Jr. Telephone: (202)434-1500 

700 Eleventh Street, N.W., Suite 500 Facsimile: (202)434-1501 
Washington, DC 20001 



® 1 997 Staas & Halsey 



APPLICATION FOR 



UNITED STATES LETTERS PATENT 



SPECIFICATION 



Inventor(s): Satoru CHIKUMA, Nobutsugu FUJINO 
and Yuichiro NOGUCHI 



Title of the Invention: RADIO COMMUNICATION SYSTEM 
AND APPARATUS, COMMUNICATION 
METHOD AND PROGRAM RECORDING 
MEDIUM THEREFOR 



RADIO COMMUNICATION SYSTEM, AND APPARATUS, 
COMMUNICATION METHOD AND PROGRAM RECORDING MEDIUM 
THEREFOR 

5 Background of the Invention 
Field of the Invention 

The present invention relates to a radio 
communication system in which different apparatuses 
communicate through a radio channel, an apparatus as 

10 well as a communication method which is used in the 
radio communication system, and a program recording 
medium which stores therein programs for incarnating 
them. More particularly, it relates to a radio 
communication system which realizes enhancement in the 

15 throughput of end-to-end data communications, an 
apparatus as well as a communication method which is 
used in the radio communication system, and a program 
recording medium which stores therein programs for 
incarnating them. 

20 

Description of the Related Art 

It has recently been common to have a portable 
terminal which is connected through a radio channel 
with a gateway connected to a public network, and 
25 which communicates with servers, connected to the 
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Internet, through the gateway. 

In such case, the throughput of end-to-end data 
communications degrades inevitably because the radio 
channel is an unstable channel. Therefore the 
5 construction of technology which realizes enhancement 
in the throughput of end-to-end data communications 
has been called for. 

In general, a computer network employs 
communications of virtual circuit type ( connection 

10 type) wherein, as in telephony, a connection is first 
set for a desired node, data are subsequently 
transmitted to and received from the connected node, 
and the connection is thereafter cleared. 

In communications of the virtual circuit type, 

15 controls such as a resending control, an error 
recovery control, a sequence control, a stream flow 
control and a congestion control are performed between 
communicating terminals (namely, between endpoint 
nodes). Thus, the reliability of the connection is 

20 guaranteed, and data in proper order can be obtained 
on the reception side without loss or change of 
transmitted information. 

There has heretofore been adopted a structure as 
shown in Fig. 1A wherein, even when a radio channel 

25 intervenes between the communicating terminals, data 
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are communicated "therebetween in accordance with the 
virtual circuit type communications. 

With such a prior-art technique, however, the 
throughput of the end-to-end data communications 
5 inevitably degrades greatly due instability of the 
radio channel. 

More specifically, as illustrated in Fig. IB, a 
resending control and an error control are performed 
as a mechanism for reliably transferring data to the 

10 opposite side, even in the protocol of the data link 
layer of the radio channel (composed of the two layers 
of a physical layer and the data link layer) 
separately from the protocol of an upper layer ( for 
example, a transport layer). 

15 In this case, when the TCP (Transmission Control 

Protocol ) , which is that transport layer protocol 
which is generally used in the Internet and which is 
mentioned as an example, the transmission node 
measures a round trip time (RTT) which is a time 

20 period required for a packet to go to and come back 
from the reception node, and it sets the time period 
of a timer for the resending control on the basis of 
the measured RTT . When a reception acknowledgement 
(ACK) is not received from the reception node within 

25 the set time period of the timer, the transmission 



node executes the processing of sending data again. 
Thus, the reliability of the data is guaranteed. 

On this occasion, when the resending of a frame 
attributed to the protocol of the data link layer has 
5 occurred in the unstable radio channel existing 
between both the terminals, a time period for this 
resending is added to the time period of the resending 
timer in the TCP, so that a long time period is set 
for the timer. For this reason, in a case where a 

10 segment in the TCP has been lost, the resending is not 
immediately activated, and the throughput of the 
end-to-end data communications degrades greatly. 

Further, according to the TCP, in the resending 
mode, congestion is regarded as the cause of the 

15 resending, and a slow start control is performed to 
suppressing the congestion. More specifically, a 
window control is ordinarily performed, in which a 
plurality of segment data is collectively sent in 
advance. In contrast, when the resending is to be 

20 initiated, the size of a window is set at the minimum 

unit so as to eliminate the cause of the congestion. 
Thereafter, the resending communications are started. 
Accordingly, the occurrence rate of ACKs (reception 
acknowledgements ) increases more than in the stable 

25 state of the data communications, and the throughput 



5 

of end-to-end data communications degrades greatly. 

The official gazette of Japanese Patent 
Application Laid-open No. 219880/1997 (filed with and 
laid open by the Japanese Patent Office) discloses a 
5 technique as stated below. In consideration of the 
fact that radio channels are unstable ones, the 
technique adopts a construction wherein each of the 
mobile terminals and servers which constitute a radio 
communication system is furnished with a buffer 

10 memory. When the radio channels are changed over, or 
when the radio channel lies in a level status in which 
data communications are likely to be cut off, data to 
be sent out to the radio channel is temporarily stored 
in the buffer memory. After the radio channels have 

15 been changed over, or when the level status of the 
radio channel is restored, the data communications are 
restarted from the data stored in the buffer memory. 

The known technique, however, does not take into 
consideration the protocol of an upper layer with 

20 respect to a data link layer. Therefore, when the 
resending control as in the TCP arises in a transport 
layer being the upper layer, the control acts in which 
a resending timer is set by adding a communicating 
time period in the radio channel . It is accordingly 

25 inevitable that the throughput of the end-to-end data 
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communications degrades greatly. 

Summary of the Invention 

The present invention has been made in view of 
5 such circumstances. It has for its object to provide, 
in adopting a construction in which different 
apparatuses communicate through a radio channel, an 
apparatus which is used in a novel radio communication 
system realizing enhancement in the throughput of 
10 end-to-end data communications, and a novel program 
recording medium which stores therein programs for 
incarnating the apparatus. 

An apparatus according to the present invention 
comprises a monitoring unit, a generation unit, a 
15 transfer unit, a transmission unit and a reception 
unit. 

In the first aspect of the present invention, the 
monitoring unit monitors whether or not a transmission 
request for data, designating the particular apparatus 

20 itself (in which this monitoring unit is included) as 
a transmission destination, has been issued by the 
particular apparatus or another apparatus connected 
thereto through a network. When the monitoring unit 
has detected the issue of the transmission request, 

25 the generation unit generates a process to serve as 
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a reception destination for the data and also 
generates a buffer held in correspondence with the 
process. The transfer unit transfers the data from 
a transmission request source to the process in 
5 accordance with communications of virtual circuit 
type, so as "to store in the buffer the data 
transferred from the request source. The transmission 
unit transmits the data stored in the buffer, to the 
other apparatus through a radio channel . 

10 In the second aspect of the present invention, 

the reception unit receives data which has been sent 
in through the radio channel . The monitoring unit 
monitors whether or not the reception unit has 
received data which conforms to a protocol suspended 

15 or interrupted in the layers of the radio channel. 

When the monitoring unit has detected the reception 
of the pertinent data, the generation unit generates 
a process to serve as a reception destination for the 
data. The transfer unit transfers the data received 

20 by the process, to a transmission request destination 
in accordance with the virtual circuit type 
communications . 

Brief Description of the Drawings 
25 Fig. 1A is a diagram for explaining 
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communications of virtual circuit type; 

Fig. IB is a diagram for explaining a prior-art 
technique; 

Fig. 2A is a block diagram showing the 
5 fundamental construction of the present invention; 

Fig. 2B is a diagram for explaining the present 
invention; 

Fig. 3 is a block diagram showing an embodiment 
of the present invention; 
10 Fig. 4 is a diagram for explaining a 

communication process; 

Fig. 5 is a flowchart showing an embodiment of 
the overall processing flow which is executed by a 
client 30 in Fig. 3; 
15 ' Fig. 6 is a flowchart showing an embodiment of 

a processing flow which is executed by the writing 
routine of the client 30; 

Fig. 7 is a flowchart showing an embodiment of 
a processing flow which is executed by the 
20 transmission routine 302 in Fig. 3 of the client 30; 

Fig. 8 is a flowchart showing an embodiment of 
a processing flow which is executed by the reception 
routine 303 in Fig. 3 of the client 30; 

Fig. 9 is a flowchart showing an embodiment of 
25 a processing flow which is executed by the reading 
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routine of the client: 30; 

Fig. 10 is a flowchart showing an embodiment of 
the overall processing flow which is executed by a 
server 40 in Fig. 3; 
5 Fig. 11 is a flowchart showing an embodiment of 

a processing flow which is executed by the reception 
routine 402 in Fig. 3 of the server 40; 

Fig. 12 is a flowchart showing an embodiment of 
a processing flow which is executed by the reading 
10 routine of the server 40; 

Fig. 13 is a flowchart showing an embodiment of 
a processing flow which is executed by the writing 
routine of the server 40; 

Fig. 14 is a flowchart showing an embodiment of 
15 a processing flow which is executed by the 
transmission routine 403 in Fig. 3 of the server 40; 

Fig. 15 is a block diagram showing the second 
embodiment of the present invention; 

Fig. 16 is a diagram for explaining a 
20 communication process; 

Fig. 17 is a flowchart showing an embodiment of 
the overall processing flow which is executed by a 
client 30 in Fig. 15 according to the second 
embodiment; 

25 Fig. 18 is a flowchart showing an embodiment of 
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•the overall processing flow which is executed by a 
gateway 50 in Fig. 15 according -to the second 
embodiment; 

Fig. 19 is a diagram for explaining a resending 
5 process; 

Fig. 20 is a diagram for explaining a format; 
Fig. 21 is a flowchart showing an embodiment of 
a processing flow which is executed by the 
transmission routine 302 in Fig. 15 of the client 30; 
10 Fig. 22 is a flowchart showing an embodiment of 

a processing flow which is executed by the reception 
routine 502 in Fig. 15 of the gateway 50; 

Fig. 23 is a flowchart showing an embodiment of 
a processing flow which is executed by the 
15 transmission routine 503 in Fig. 15 of the gateway 50; 

Fig. 24 is a flowchart showing an embodiment of 
a processing flow which is executed by the reception 
routine 303 in Fig. 15 of the client 30; 

Fig. 25 is a block diagram showing the third 
20 embodiment of the present invention; 

Fig. 26 is a flowchart showing an embodiment of 
a processing flow which is executed by the 
transmission routine 302 in Fig. 25 of a client 30 in 
Fig. 25 according to the third embodiment; 
25 Fig. 27 is a flowchart showing an embodiment of 
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a processing flow which is executed by the 
transmission routine 403 in Fig. 25 of a server 40 in 
Fig. 25 according to the third embodiment; 

Fig. 28 is a block diagram showing the fourth 
5 embodiment of the present invention; 

Fig. 29 is flowcharts showing embodiments of a 
processing flow which is executed by a data transfer 
control program 309 in Fig. 28; 

Fig. 30 is a block diagram showing the fifth 
10 embodiment of the present invention; 

Fig. 31 is a block diagram showing the sixth 
embodiment of the present invention; 

Fig. 32 is a block diagram showing the seventh 
embodiment of the present invention; and 
15 Fig. 33 is a diagram for explaining a system to 

which the present invention is applied. 

Description of the Preferred Embodiment 

Now, the present invention will be described in 
20 detail with reference to the drawings. 

Referring to Fig. 2A, a transmission side 
apparatus 1 is an apparatus to which the present 
invention is applied, and a reception side apparatus 
2 is also an apparatus to which the present invention 
25 is applied. The transmission side apparatus 1 of the 
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present invention communicates with the reception side 
apparatus 2 of the present invention through a radio 
channel . 

The transmission side apparatus 1 of the present 
5 invention comprises a monitoring unit 10, a generation 
unit 11, a process (which has substantially the same 
significance as that of a "thread" or "routine") 12, 
a buffer 13, a transfer unit 14, a transmission unit 
15, a detection unit 16, a specification unit 17, a 

10 cache memory 18 and a search unit 19. 

The monitoring unit 10 monitors whether or not 
a transmission request for data, designating the 
particular apparatus itself (in which this monitoring 
unit 10 is included) as a transmission destination, 

15 has been issued by the particular apparatus or another 
apparatus connected thereto through a network. When 
the monitoring unit 10 has detected the issue of the 
data transmission request designating the particular 
apparatus as the transmission destination, the 

20 generation unit 11 generates the process 12 which is 
to serve as a reception destination for the data and 
also generates the buffer 13 in correspondence with 
the process 12. 

The transfer unit 14 transfers the data requested 

25 by a transmission request source, to the process 12 
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in accordance with communications of virtual circuit 
type. Then, the process 12 stores the received data 
in the buffer 13. The transmission unit 15 transmits 
the data stored in the buffer 13, to the other 
5 apparatus through the radio channel. The detection 
unit 16 detects the data storing state of the buffer 
13. 

When the radio channel has been disconnected 
during the data transmission, the specification unit 

10 17 specifies the sequence number of the transmission 
data at the point of time of the disconnection. The 
cache memory 18 stores therein data which has been 
received in response to the data transmission from the 
transmission unit 15. The search unit 19 makes a 

15 search as to whether or not the data requested by the 
transmission request source is registered in the cache 
memory 18. 

On the other hand, the reception side apparatus 
2 of the present invention comprises a reception unit 
20 20, a monitoring unit 21, a generation unit 22, a 
process 23, a transfer unit 24, a cache memory 25 and 
a search unit 26. 

The reception unit 20 receives data which has 
been sent in through the radio channel. The 
25 monitoring unit 21 monitors whether or not the 
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reception unit 20 has received data which conforms to 
a protocol suspended or interrupted in the layers of 
the radio channel. 

When the monitoring unit 21 has detected the 
5 reception of the pertinent data, the generation unit 
22 generates the process 23 which is to serve as a 
reception destination for the data. The transfer unit 
24 transfers the data received by the process 23, to 
a transmission request destination in accordance with 

10 the virtual circuit type communications. 

The cache memory 25 stores therein the data which 
has been received in response to the data transfer 
from the transfer unit 24. The search unit 26 makes 
a search as to whether or not the data requested by 

15 the data sent in through the radio channel is 
registered in the cache memory 25. 

Here, the functions bestowed on the transmission 
side apparatus 1 of the present invention and the 
functions bestowed on the reception side apparatus 2 

20 of the present invention are concretely incarnated by 
programs. The programs are stored in a portable 
recording medium such as a floppy disk, the hard disk 
of a server, and so forth. Such programs are 
installed from the storage media into the transmission 

25 side apparatus 1 and reception side apparatus 2, and 
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they are loaded into memories and are run by CPUs 
(central processing units). Thus, the present 
invention is realized. 

The transmission side apparatus 1 of the present 
5 invention thus constructed operates as explained 
below. When the monitoring unit 10 has detected that 
a transmission request for data, designating the 
particular apparatus 1 itself as a transmission 
destination, has been issued by the particular 

10 apparatus 1 or another apparatus connected thereto 
through a network, the generation unit 11 generates 
the process 12 to serve as a reception destination for 
the data and also generates the buffer 13 in 
correspondence with the process 12 . 

15 Upon the generation processing of the generation 

unit 11, the transfer unit 14 transfers the data 
requested by the transmission request source, to the 
process 12 in accordance with communications of 
virtual circuit type. The process 12 stores the 

20 received data in the buffer 13. Then, the 

transmission unit 15 transmits the data stored in the 
buffer 13, to the other apparatus through the radio 
channel . 

On this occasion, in issuing the request for the 
25 data transmission, the particular apparatus 1 is 



16 

designated as the transmission destination, and any- 
other apparatus is not designated as such. Therefore, 
the transmission unit 15 sometimes transmits 
transmission destination information which is to be 
5 designated in an upper layer with respect to the 
layers of the radio channel, in the way, for example, 
that the address of the other apparatus as the 
transmission destination is acquired by referring to 
a file which manages the mapping relations between the 

10 destinations of transmission requests and the 
addresses of apparatuses expanding the requests, 
whereupon the data is transmitted to the other 
apparatus of the acquired address. Due to this 
contrivance, the transmission side apparatus 1 

15 operates as a proxy which makes it seem as if the 
transmission destination existed therein, to the 
transmission request source for the data. 

Thus, according to the transmission side 
apparatus 1 of the present invention, enhancement in 

20 the throughput of end-to-end data communications is 
realized in such a way that, as illustrated in Fig. 
2B, a resending control for guaranteeing data, which 
conforms to the protocol of a transport layer (layer 
#4), is terminated on this side of the radio channel, 

25 while the data transmission over the unstable radio 
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channel is performed by utilizing the protocol of the 
data link layer ( layer #2 ) of the radio channel . 

In the case of adopting the contrivance, when the 
detection unit 16 has detected that the buffer 13 is 
5 about to overflow, the transfer unit 14 controls the 
communication speed of the virtual circuit type 
communications so as to lower, thereby to prevent the 
buffer 13 from overflowing. 

In addition, when the specification unit 17 has 

10 specified the sequence number of the transmission data 
at the point of time of the disconnection of the radio 
channel, the transmission unit 15 restarts the data 
transmission from the specified sequence number upon 
the re-connection of the radio channel, thereby 

15 performing a control for the avoidance of transmitting 
data already received by the opposite apparatus, again 
over the radio channel. 

In addition, in some cases, a plurality of 
buffers 13 are concurrently generated, and the 

20 transmission unit 15 transmits data successively in 
the order of the preset priority levels of the buffers 
13 or transmits data while setting the transmission 
cycles of the buffers 13 of the higher priority levels 
to be shorter. 

25 Further, when the search unit 19 searching the 
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cache memory 18 has detected that the data requested 
by the transmission request source is registered in 
the cache memory 18, the detected data in the cache 
memory 18 is immediately notified to the transmission 
5 request source without executing the transmission 
processing by the transmission unit 15. 

On the other hand, the reception side apparatus 
2 of the present invention constructed as stated 
before operates as explained below. When the 

10 reception unit 20 has received data conforming to a 
protocol suspended in the layers of the radio channel, 
the generation unit 22 generates the process 23 to 
serve as a reception destination for the data. 

Upon the generation processing of the generation 

15 unit 22, the transfer unit 24 transfers the data 
received by the generated process 23, to the 
transmission request destination in accordance with 
the virtual circuit type communications. 

Thus, according to the reception side apparatus 

20 2 of the present invention, enhancement in the 
throughput of end-to-end data communications is 
realized in such a way that a resending control for 
guaranteeing data, which is performed in a transport 
layer, is terminated on this side of the radio 

25 channel, while regarding the data transmission over 
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the unstable radio channel, the data transmitted from 
the transmission side apparatus 1 of the present 
invention is received by utilizing the protocol of the 
data link layer of the radio channel. 
5 In the case of adopting the contrivance, when the 

search unit 26 searching the cache memory 25 has 
detected that the data requested by the transmission 
request source is registered in the cache memory 25, 
the detected data in the cache memory 25 is 

10 immediately notified to the transmission request 
source without the operation of the transfer unit 24 
that the data from the transmission request source is 
transferred to the transmission request destination. 
As thus far explained, according to the present 

15 invention, the resending control for guaranteeing data 
as it proceeds with the protocol of the transport 
layer is terminated on this side of the radio channel, 
while the data transmission over the unstable radio 
channel is carried out by utilizing the protocol of 

20 the data link layer of the radio channel. It is 
accordingly possible to realize enhancement in the 
throughput of end-to-end data communications. 

Moreover, according to the present invention, the 
apparatus is permitted to operate as the proxy which 

25 makes it seem as if the transmission request 



20 

destination existed therein (for example, in the 
particular apparatus itself ) , to the transmission 
request source for the data. 

In the embodiments to be described below, it is 
5 assumed that the TCP ( Transmission Control Protocol ) 
and the IP (Internet Protocol) which are generally 
used in the Internet are respectively employed as the 
protocols of a transport layer and a network layer. 

Fig. 3 is a block diagram showing the 

10 architecture of an information system in an embodiment 
of the present invention. 

Referring to the figure, a client 30 is an 
apparatus which expands and runs any of application 
programs 300 on a memory so as to issue a service 

15 request. On the other hand, a server 40 is an 
apparatus which expands and runs any of several 
service programs 400 such as SMTP, FTP, TELNET, rep, 
rlogin and HTTP, on a memory, which is communicatively 
connected with the client 30 through a radio channel 

20 and which offers a service to the client 30. 

Incidentally, it is assumed in this embodiment that 
the client 30 and the server 40 communicate in 
one-to-one correspondence. 

The client 30 includes a radio equipment 301 

25 which is configured of a portable telephone and a data 
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communication adaptor, a transmission routine 302 
which is generated and activated as a thread or 
process and which transmits data through an interface 
for connecting the radio equipment 301, a reception 
5 routine 303 which receives data through the interface 
for connecting the radio equipment 301, a daemon 
program 304 which monitors a port number designated 
by the TCP ( for designating the service program 400 ) , 
a child process 305 which is generated when the 

10 application program 300 has issued a service request 
by designating a "service program name (or port 
number), localhost" as a destination and which accepts 
data issued by the application program 300, in 
accordance with communications of the virtual circuit 

15 type (connection type) by the use of a socket extended 
between this child process 305 and the application 
program 300, and a buffer 306 which is generated in 
correspondence with the child process 305 and in which 
the data accepted by the child process 305 is stored. 

20 Here, "localhost" indicates the IP address (the 

address of a node designated by the IP) of the 
particular apparatus itself. The above "service 
program name (or port number), localhost" signifies 
that the service program 400 which is expanded in the 

25 memory of the particular apparatus (the program 400 
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need not always be already expanded) is designated as 
the destination. 

On the other hand, the server 40 includes a radio 
equipment 401 which is configured of a portable 
5 telephone and a data communication adaptor, a 
reception routine 402 which receives data through an 
interface for connecting the radio equipment 401, a 
transmission routine 403 which transmits data through 
the interface for connecting the radio equipment 401, 

10 a daemon program 404 which monitors whether or not the 
reception routine 402 has received data destined for 
the particular apparatus itself and conforming to the 
protocol suspended in the layer of the radio channel, 
a child process 405 which is generated when the daemon 

15 program 404 has detected the reception of the 
pertinent data and which transfers the data sent in 
from the client 30, to the service program 400 in 
accordance with the virtual circuit type (connection 
type) communications by the use of a socket extended 

20 between this child process 405 and the service program 
400, and a service daemon program 406 which monitors 
a destination port number accepted by the child 
process 405 and which activates the service program 
400 pointed to by the destination port number. 

25 Incidentally, although no illustration is made 
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in Fig. 3, the server 40 acting as the reception side 
is also furnished with a buffer in correspondence with 
the reception routine 402. As will be explained 
later, however, the buffer is not disposed for 
5 absorbing the difference between the speeds of data 
transfer, but it is disposed for merely delivering 
data to the memory ( the exchange of data through the 
memory ) . 

Here, the programs which are expanded on the 
10 memories of the client 30 and the server 40 are stored 
in a portable recording medium such as a floppy disk, 
the hard disk of a server, and so forth, and they are 
installed from them. 

In the case of employing the TCP, the information 
15 system is so constructed that the program on the 
transmission side and the program on the reception 
side are communicatively connected by designating the 
transmission-source port number and the destination 
port number. 

20 In the embodiment of Fig. 3 thus constructed, 

therefore, the client 30 monitors the ports by running 
the daemon program 304 and waits for a connection 
request from the application program 300. 

Under this state, the application program 300 is 

25 activated as indicated by "1 activation" in the 
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figure. Then, when a service which is offered by the 
server 40 is required, the application program 300 
issues a service request by designating the address 
"localhost" for commanding the radio equipment 301 to 
5 establish a connection to the particular apparatus 
itself, together with the port number which specifies 
the service program 400 offering the service. 
Therefore, the daemon program 304 monitors the ports 
as indicated by "2 port monitoring" in the figure, 

10 thereby monitoring whether or not the service request 
designating the address "localhost" has been issued 
by the application program 300. 

Upon detecting that the application program 300 
has issued the service request by designatincr the 

15 address "localhost", the daemon program 304 generates 
the child process 305 for the intermediation 
processing of data transfer as indicated by "3 fork" 
in the figure, by issuing a system call "fork" by way 
of example, and also generates the buffer 306 in 

20 correspondence with the child process 305, in order 
to transmit data to the server 40. The child process 
305 and the buffer 306 are generated in correspondence 
with a session number which functions as the 
identification number of the application program 300. 

25 When the child process 305 has been generated, 
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the application program 300 establishes a socket 
connection between it and the child process 305 as 
indicated by "4 socket" in the figure, and it 
transfers the data to be transmitted to the server 40, 
5 to the child process 305 by the use of the virtual 
circuit type communications. Upon accepting the data, 
the child process 305 commands the radio equipment 301 
to establish the connection to the radio channel, as 
indicated by "5 connection command" in the figure, 

10 thereby connecting the radio channel, and stores the 
data transferred from the application program 300, in 
the buffer 306. Then, the transmission routine 302 
sends out the data stored in the buffer 306, to the 
radio equipment 301. 

15 Heretofore, the application program 300 of the 

client 30 has issued a service request by designating 
the service program 400 to become a service request 
destination, for the service daemon program 406 of the 
server 40. In contrast, according to this embodiment, 

20 the application program 300 issues the service request 
by designating the address "localhost" to function as 
the IP address of the particular apparatus itself. 
Owing to this processing, the child process 305 stores 
the data to be transmitted to the server 40, in the 

25 buffer 306 within the client 30 in accordance with the 
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virtual circuit type communications having no unstable 
factor . 

In this manner, the client 30 of this embodiment 
is so contrived that a resending control for 
5 guaranteeing data, which is performed in conformity 
with the transport layer protocol, is once terminated 
on this side of the radio channel. 

Upon accepting a transmission command from the 
child process 305, the radio equipment 301 transmits 

10 the data of the buffer 306 sent in by the sending-out 
processing of the transmission routine 302, to the 
server 40 through the radio channel while performing 
a resending control in the data link layer of the 
radio channel, and so forth. 

15 In the transmission processing over the radio 

channel, a transmission speed is low because the radio 
channel is unstable. Therefore, the buffer 306 is 
disposed in order to absorb the speed difference 
between the transmission speed and the high speed of 

20 the data transfer from the application program 300 to 
the child process 305 . 

As stated above, the application program 300 of 
the client 30 has heretofore issued the service 
request by designating the service program 400 to 

25 become the service request destination, for the 
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service daemon program 406 of the server 40, whereas 
in this embodiment , the application program 300 issues 
the service request by designating the address 
"localhost" to function as the IP address of the 
5 particular apparatus itself, thereby terminating the 
protocols TCP/IP on this side of the radio channel. 
Accordingly, the server 40 cannot activate the service 
program 400 when left intact. 

More specifically, if the protocols TCP/IP are 

10 not terminated, the port number and IP address which 
are designated by the protocols TCP/IP are notified 
to the server 40 in the state in which they are 
wrapped in the header of the frame of the layers of 
the radio channel. In contrast, when the protocols 

15 TCP/IP are terminated on this side of the radio 
channel, the port number and IP address designated by 
the protocols TCP/IP are not notified to the server 
40. In consequence, the server 40 cannot activate the 
service program 400. 

20 Therefore, processing as illustrated in Fig. 4 

is executed. In issuing a service request to the 
server 40, the client 30 sends the server 40, for 
example, the port number designated by the application 
program 300 and the session number (Sn) of the 

25 application program 300 before the transmission of 
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data. Subsequently, the client 30 transmits the data. 

Here, the session numbers are numbers which are 
assigned to the respective application programs 300. 
When the different application programs 300 have 
5 issued service requests for the service program 400 
specified by the same port number, the service 
requests of the individual application programs 300 
are identified by the session numbers. Incidentally, 
the session numbers are assigned by the daemon program 

10 304, while the port numbers are assigned by an OS 
( operating system ) . 

Herein, on the side of the server 40, the daemon 
program 404 monitors whether or not the reception 
routine 402 has received data (transmitted by the 

15 client 30) destined for the particular apparatus 
itself and conforming to the protocol suspended in the 
layer of the radio channel, as indicated by "6 
monitoring" in Fig. 3. Upon detecting that the 
reception routine 402 has received the pertinent data, 

20 the daemon program 404 generates the child process 405 
for accepting the data received by the reception 
routine 402, as indicated by "7 fork" in Fig. 3 and 
by issuing a system call "fork" by way of example, in 
order to transfer data to the service program 400. 

25 Here, the child process 405 is generated in 
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correspondence with the session number functioning as 
the identification number of the application program 
300, likewise to that 305 of the client 30. 

When thus generated, the child process 405 issues 
5 a connection request as indicated by "8 connection 
request" in Fig. 3, for the service daemon program 406 
specified by the port number sent in from the client 
30 ( the program 406 operates to activate the service 
program 400 specified by the port number). As 

10 indicated by "9 activation" in Fig. 3, the service 
daemon program 406 responds to the connection request 
to activate the service program 400 which offers the 
service requested by the application program 300. 

Upon activation, the child process 405 

15 establishes a socket connection between it and the 
activated service program 400, as indicated by "10 
socket" in Fig. 3, and it transfers the data sent in 
from the client 30, to the service program 400 by the 
use of virtual circuit type communications. 

20 In this way, the server 40 of the embodiment 

receives the data sent in from the client 30 of the 
embodiment . 

This embodiment shown in Fig. 3 has been 
described on the processing in the case where the 
25 client 30 issues the service request and notifies the 
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issue to the server 40. In a case where, in response 
to the service request, the service program 400 
executes the service and returns the result of the 
service to the application program 300, the 
5 transmission processing of the client 30 explained in 
conjunction with Fig. 3 is executed by the server 40, 
and the reception processing of the server 40 
explained in conjunction with Fig. 3 is executed by 
the client 30. 

10 Next, there will be explained those processing 

flows of Figs. 5 through 14 which are executed in the 
embodiment constructed as described above in 
conjunction with Fig. 3. 

Here, Fig. 5 illustrates an embodiment of the 

15 overall processing flow which is executed by the 
client 30, Fig. 6 illustrates an embodiment of the 
processing flow which is executed by the writing 
routine of the client 30, Fig. 7 illustrates an 
embodiment of the processing flow which is executed 

20 by the transmission routine 302 of the client 30, Fig. 

8 illustrates an embodiment of the processing flow 
which is executed by the reception routine 303 of the 
client 30, Fig. 9 illustrates an embodiment of the 
processing flow which is executed by the reading 

25 routine of the client 30, Fig. 10 illustrates an 
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embodiment of the overall processing flow which is 
executed by the server 40, Fig. 11 illustrates an 
embodiment of the processing flow which is executed 
by the reception routine 402 of the server 40, Fig. 
5 12 illustrates an embodiment of the processing flow 
which is executed by the reading routine of the server 
40, Fig. 13 illustrates an embodiment of the 
processing flow which is executed by the writing 
routine of the server 40, and Fig. 14 illustrates an 

10 embodiment of the processing flow which is executed 
by the transmission routine 403 of the server 40. 

As shown in the processing flow of Fig. 5, first 
of all, the client 30 executes initialization 
processing and prepares a socket in step ST1. 

15 Subsequently, the transmission routine 302 functioning 
as a transmission thread (the word "thread" has 
substantially the same significance as that of a 
"process" or "routine") is activated in step ST2, and 
the reception routine 303 functioning as a reception 

20 thread is activated in step ST3 . 

Further, in step ST4, the client 30 waits until 
a connection request for a port designating an address 
"localhost" is issued by the application program 300. 
When the connection request has been issued, the 

25 processing flow proceeds to step ST5, in which the 



daemon program 304 generates the child process 305 and 
the buffer 306. 

When the child process 305 has been generated, 
the socket is extended between the application program 
5 300 and the child process 305 in step ST6. 
Subsequently, a session number corresponding to the 
socket is acquired from the daemon program 304 and is 
stored in step ST7. Further, whether or not the radio 
channel has been connected is determined in step T8 . 

10 Subject to the determination that the radio channel 
is not connected yet, the processing flow proceeds to 
step ST9, at which the radio channel is connected, and 
which is followed by step ST10. On the other hand, 
subject to the determination of step ST8 that the 

15 radio channel has already been connected, step ST8 is 
immediately followed by step ST10. 

In step ST10, a control packet with the session 
number affixed to port number information is generated 
and is written into the buffer 306. Next, in step 

20 ST11, data sent in from the socket (data transferred 
by the application program 300) is written into the 
buffer 306 in accordance with a writing routine (which 
executes the processing of writing into the buffer 
306, and which is prepared in correspondence with the 

25 buffer 306 by way of example). Simultaneously, the 
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data stored in the buffer 306 is transmitted to the 
server 40 through the radio channel in accordance with 
the transmission routine 302. 

Here, in a case where the client 30 acts as a 
5 reception side, processing as indicated by step ST12 
is executed. Concretely, data transmitted from the 
server 40 is received into a reception buffer for 
merely delivering the data to a memory (the buffer 
being a storage area for the received data, which is 

10 used for exchanging the received data between the 
reception routine 303 and a reading routine*) in 
accordance with the reception routine 303, while at 
the same time, the data is read out of the reception 
buffer and is thrown into the socket in accordance 

15 with the reading routine (which executes the 
processing of reading from the reception buffer, and 
which is prepared in correspondence with the reception 
buffer by way of example). 

Subsequently, whether or not all the 

20 communications have been completed is determined in 
step ST13. Subject to the determination that all the 
communications have not been completed, the processing 
of the pertinent session is terminated without 
disconnecting the radio channel. On the other hand, 

25 subject to the determination that all the 



34 

communications have been completed, the radio channel 
is disconnected in step ST14, whereupon the processing 
is terminated. 

The processing of the writing routine which is 
5 executed in step ST11 in Fig. 5 is as illustrated in 
the processing flow of Fig. 6. Data is read out of 
the socket, a header containing the corresponding 
session number is affixed to the read data, and the 
resulting data is written into the buffer 306. 

10 Subsequently, whether or not the socket continues to 
exist is determined. When the continuation of the 
socket has been determined, whether or not data exists 
is determined. When the existence of the data has 
been determined, the processing flow returns to the 

15 first step, from which the above processing is 
iterated. 

In addition, the processing of the transmission 
routine 302 in Fig. 3 as is executed in this 
embodiment is as illustrated in the processing flow 

20 of Fig. 7. First, whether or not data is stored in 
the buffer 306 is determined. Subject to the 
determination that the data is stored, the data is 
read out of the buffer 306 and is transferred to the 
radio channel. Incidentally, when the radio channel 

25 is disconnected on this occasion, the data is resent 
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after the re-connection of the radio channel. In 
contrast, when the radio channel is not disconnected, 
the data transferred from the buffer 306 is cleared, 
whereupon the processing flow returns to the first 
5 step . 

Besides, the processing of the reception routine 
303 in Fig. 3, which operates when the client 30 acts 
as the reception side, is as illustrated in "the 
processing flow of Fig. 8. First, whether or not data 

10 from the radio channel exists is determined. Subject 
to the judgment that the data exists, the data is read 
out and is written into the reception buffer for 
merely delivering the data to the memory as explained 
before. Subsequently, whether or not the radio 

15 channel has been disconnected is determined. In case 
of the disconnection, the radio channel is 
re-connected. Thereafter, the above processing is 
iterated. 

Besides, the processing of the reading routine, 
20 which operates in step ST12 in Fig. 5 when the client 
30 acts as the reception side, is as illustrated in 
the processing flow of Fig. 9. The first step 
determines whether or not data is stored in the 
reception buffer for merely delivering the data to the 
25 memory as explained before. Subject to the 
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de-termination that the data is stored, the data is 
read out of the reception buffer and has its header 
detached therefrom. Subsequently, whether or not the 
data is a control packet is determined from the 
5 header. When the received data is the control packet, 
control information designated by the control packet 
is processed. In contrast, when the received data is 
not the control packet, that is, when it is 
communication data, it is sent out to a socket pointed 
10 to by a session number. The series of processing 
explained above is executed while the socket continues 
to exist. 

On the other hand, first of all, the server 40 
subjected to the data transmission from the client 30 

15 executes initialization processing and prepax-es a 
socket in step ST1 as shown in the processing flow of 
Fig. 10. Subsequently, the arrival of data at the 
radio channel is waited in step ST2. When the arrival 
at the radio channel has been detected, the 

20 transmission routine 403 to function as a transmission 
thread is activated in step ST3, and the reception 
routine 402 to function as a reception thread is 
activated in step ST4. 

Further, in step ST5, the server 40 waits until 

25 port number information is stored in a reception 
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buffer for merely delivering data to a memory as 
explained above. As long as the port number 
information is ' not stored, the processing flow 
proceeds to step ST6 , at which the radio channel is 
5 disconnected and which is followed by step ST2. On 
the other hand, in a case where the port number 
information is stored, the processing flow proceeds 
to step ST7, at which the child process 405 is 
generated in correspondence with a session number. 

10 When the child process 405 has been generated, 

the socket is extended between the service program 400 
of a service request destination and the child process 
405 in accordance with the port number information in 
step ST8. Subsequently, the corresponding relation 

15 between the socket and the session number is stored 
in step ST9 . 

Subsequently, processing as indicated by step 
ST11 is executed. Concretely, data sent in through 
the radio channel is received and is stored into the 

20 reception buffer for merely delivering the data to the 
memory, in accordance with the reception routine 402, 
while at the same time, the received data is read out 
of the reception buffer and is thrown into the socket 
in accordance with a reading routine (which executes 

25 the processing of reading from the reception buffer, 
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and which is prepared in correspondence with the 
reception buffer by way of example). Thus, the 
received data is transferred to the service program 
400. 

5 Here, in a case where the server 40 acts as a 

transmission side, processing as indicated by step 
ST10 is executed. Concretely, data to be transmitted 
is written into a buffer corresponding to the buffer 
306 of the client 30, in accordance with a writing 

10 routine (which is prepared in correspondence with the 
buffer by way of example), while at the same time, the 
data stored in the buffer is transmitted to the client 
30 through the radio channel in accordance with the 
transmission routine 403 . 

15 Lastly, the socket is released in step ST12 to 

terminate the processing of the server 40. 

The processing of the reception routine 402 in 
Fig. 3 as is executed in this embodiment is as 
illustrated in the processing flow of Fig. 11. First, 

20 whether or not the radio channel is disconnected is 
determined. Subject to the determination that the 
radio channel is disconnected, a re-connection timer 
is activated. The next step determines whether or not 
the radio channel has been re-connected within the 

25 preset time period of the re-connection timer. When 
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the re-connection has been determined, the 
re-connection timer is stopped. More specifically, 
when the radio channel is disconnected, the client 30 
being the transmission side tries to re-connect the 
5 radio channel, and hence, the server 40 waits the 
trial. Meanwhile, when the radio channel is not 
disconnected as the determination of the first step, 
it is iterated to execute the processing of receiving 
data from the radio channel and writing the data into 

10 the reception buffer for merely delivering the data 
to the memory as stated before. 

In addition, the processing of the reading 
routine which is executed in step ST11 in Fig. 10 in 
this embodiment is as illustrated in the processing 

15 flow of Fig. 12. The first step determines whether 
or not data is stored in the reception buffer for 
merely delivering the data to the memory. Subject to 
the determination that the data is stored, the data 
is read out of the reception buffer and has its header 

20 detached therefrom. Subsequently, whether or not the 
data is a control packet is determined from the 
header. When the received data is the control packet, 
control information designated by the control packet 
is processed. In contrast, when the received data is 

25 not the control packet, that is, when it is 
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communication data, it is sent out to a socket pointed 
to by a session number. The series of processing 
explained above is executed while the socket continues 
to exist. 

5 Besides, the processing of the writing routine, 

which operates in step ST10 in Fig. 10 when the server 
40 acts as the transmission side, is as illustrated 
in the processing flow of Fig. 13. Data is read out 
of the socket, a header containing the corresponding 

10 session number is affixed to the read data, and the 
resulting data is written into a buffer corresponding 
to the buffer 306 of the client 30. Subsequently, 
whether or not the socket continues to exist is 
determined. When the continuation of the socket has 

15 been determined, the processing flow returns to the 
first step, from which the above processing is 
iterated. 

Besides, the processing of the transmission 
routine 403 in Fig. 3, which operates when the server 

20 40 acts as the transmission side, is as illustrated 
in the processing flow of Fig. 14. The first step 
determines whether or not data is stored in the buffer 
corresponding to the buffer 306 of the client 30. 
Subject to the determination that the data is stored, 

25 the data is read out of the buffer and is transferred 



41 

to the radio channel. Incidentally, when the radio 
channel is disconnected on this occasion, it is 
re-connected on condition that a re-connection timer 
does not time over, and the data is resent. In 
5 contrast, when the radio channel is not disconnected, 
the data transferred from the buffer is cleared, 
whereupon the processing flow returns to the first 
step . 

As thus far described, according to the above 

10 embodiments, the resending control for guaranteeing 
data as proceeds with the protocol of the transport 
layer is terminated on this side of the radio channel, 
while the data transmission over the unstable radio 
channel is carried out by utilizing the protocol of 

15 the data link layer of the radio channel. It is 
accordingly possible to realize enhancement in the 
throughput of the end-to-end data communications. 

Moreover, the apparatus is permitted to operate 
as the proxy which makes it seem as if the 

20 transmission request destination existed therein, to 
the transmission request source for the data. 

Now, reference will be had to Fig. 15 showing an 
information system in the second embodiment of the 
present invention. 

25 The point of difference of the second embodiment 
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from the first embodiment described in conjunction 
with Fig. 3 is that, in the first embodiment shown in 
Fig. 3, the arrival destination of the radio 
transmission is the server 40 in which the service 
5 program 400 is expanded, whereas in the second 
embodiment, the arrival destination of radio 
transmission is a gateway 50 to which a server 40 for 
expanding a service program 400 is connected through 
the Internet 60. 

10 Owing to the architectural difference, the 

gateway 50 includes a radio equipment 501, a reception 
routine 502, a transmission routine 503, a daemon 
program 504 which monitors whether or not the 
reception routine 502 has received data (transmitted 

15 by a client 30) conforming to a protocol suspended in 
the layer of a radio channel, and a child process 505 
which is generated when the daemon program 504 has 
detected the reception of the pertinent data and which 
transfers the data sent in from the client 30, to the 

20 service program 400 in accordance with communications 
of virtual circuit type by the use of a socket 
extended between this child process 505 and the 
service program 400. 

On the other hand, the server 40 includes a 

25 service daemon program 406 which monitors a 
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destination port number accepted by the child process 
505 and which activates the service program 400 
pointed to by the destination port number. 

Further, the client 30 includes a setting file 
5 307 which manages the corresponding relations between 
port numbers and IP addresses, while the gateway 50 
includes a setting file 506 which manages the 
corresponding relations between the port numbers and 
the IP addresses. 

10 In the second embodiment of Fig. 15 thus 

constructed, the client 30 monitors the ports by 
running a daemon program 304 and waits a connection 
request from an application program 300. 

Under this state, the application program 300 is 

15 activated as indicated by "1 activation" in Fig. 15. 

Then, when a service which is offered by the server 
40 is required, the application program 300 issues a 
service request by designating an address 
"localhosf'for commanding a radio equipment 301 to 

20 establish a connection to the particular apparatus 
itself, together with the port number which specifies 
the service program 400. Therefore, the daemon 
program 304 monitors the ports as indicated by "2 
port monitoring" in the figure, thereby to monitor 

25 whether or not the service request designating the 
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address "localhost" has been issued. 

Upon detecting that the application program 300 
has issued the service request by designating the 
address "localhost", the daemon program 304 generates 
5 a child process 305 for the intermediation processing 
of data transfer as indicated by "3 fork" in the 
figure, by issuing a system call "fork" by way of 
example, and also generates a buffer 306 in 
correspondence with the child process 305, in order 

10 to transmit data to the server 40. The child process 
305 and the buffer 306 are generated in correspondence 
with a session number which functions as the 
identification number of the application program 300. 
When the child process 305 has been generated, 

15 the application program 300 establishes a socket 
connection between it and the child process 305 as 
indicated by "4 socket" in the figure, and it 
transfers the data to be transmitted to the server 40, 
to the child process 305 by the use of the virtual 

20 circuit type communications. Upon accepting the data, 
the child process 305 commands the radio equipment 301 
to establish the connection to the radio channel, as 
indicated by "5 connection command" in the figure, 
thereby connecting the radio channel, and it stores 

25 the data transferred from the application program 300, 
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in -the buffer 306. Then, a transmission routine 302 
sends out the data stored in the buffer 306, to the 
radio equipment 301 . 

On this occasion, since the address "localhost" 
5 is designated, the child process 305 cannot know the 
IP address of the server 40 connected ahead of the 
Internet 60. Therefore, the child process 305 obtains 
the IP address of the server 40 in such a way that, 
as indicated by "6 reference" in the figure, the 
10 setting file 307 is referred to using a search key 
which is the port number designated by the application 
program 300. 

Upon accepting a transmission command from the 
child process 305, the radio equipment 301 transmits 

15 the stored data of the buffer 306 sent in by the 
sending-out processing of the transmission routine 
302, to the server 40 through the radio channel while 
performing a resending control in the data link layer 
of the radio channel, and so forth. 

20 As stated before, the application program 300 of 

the client 30 has heretofore issued the service 
request, by designating the service program 400 to 
become the service request destination, for the 
service daemon program 406 of the server 40, whereas 

25 in this embodiment, the application program 300 issues 
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the service request by designating the address 
"localhost" to function as the IP address of the 
particular apparatus itself, thereby terminating the 
protocols TCP/IP on this side of the radio channel. 
5 Accordingly, the server 40 cannot activate the service 
program 400 when left intact. 

Therefore, processing as illustrated in Fig. 16 
is executed. In issuing a service request to the 
server 40, the transmission routine 302 sends the 

10 gateway 50, for example, the IP address of the server 
40 derived from the setting file 307 by the above 
processing and also the port number designated by the 
application program 300, as well as the session number 
(Sn) of the application program 300, before the 

15 transmission of data. Subsequently, the client 30 
transmits the data. 

Herein, on the side of the gateway 50, the daemon 
program 504 monitors whether or not the reception 
routine 502 has received data (transmitted by the 

20 client 30) conforming to the protocol suspended in the 
layer of the radio channel, as indicated by "7 
monitoring" in Fig. 15. Upon detecting that the 
reception routine 502 has received the pertinent data, 
the daemon program 504 generates the child process 505 

25 for accepting the data received by the reception 
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routine 502, as indicated by "8 fork" in the figure 
and by issuing a system call "fork" by way of example, 
in order to transfer data to the service program 400. 
Here, the child process 505 is generated in 
5 correspondence with the session number functioning as 
the identification number of the application program 
300, likewise to the child process 305 of the client 
30. 

When thus generated, the child process 505 issues 
10 a connection request as indicated by "10 connection 
request" in Fig. 15, for the server 40 pointed to by 
the IP address sent in from the client 30, while 
designating the service daemon program 406 specified 
by the port number sent in from the client 30., As 
15 indicated by "11 activation" in the figure, the 
service daemon program 406 responds to the connection 
request to activate the service program 400 which 
offers the service requested by the application 
program 300 . 

20 When the IP address has not been sent in from the 

client 30, the child process 505 of the gateway 50 
obtains the IP address of the server 40 in such a way 
that, as indicated by "9 reference" in Fig. 15, the 
setting file 506 is referred to using a search key 

25 which is the port number notified by the client 30. 
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Upon the activation of the service program 400, 
the child process 505 establishes the socket 
connection between it and the activated service 
program 400, as indicated by "12 socket" in the 
5 figure, and it transfers the data sent in from the 
client 30, to the service program 400 by the use of 
virtual circuit type communications. 

In this way, the server 40 of the second 
embodiment according to the present invention receives 

10 the data sent in from the client 30 of the second 
embodiment according to the present invention. 

The second embodiment shown in Fig. 15 has been 
described on the processing in the case where the 
client 30 issues the service request and notifies the 

15 issue to the server 40. In a case where, in response 
to the service request, the service program 400 
executes the service and returns the result of the 
service to the application program 300, the 
transmission processing of the client 30 explained in 

20 conjunction with Fig. 15 is executed by the server 40, 
and the reception processing of the server 40 
explained in conjunction with Fig. 15 is executed by 
the client 30. 

Fig. 17 illustrates an embodiment of the overall 

25 processing flow which is executed by the client 30 of 
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the second embodiment: shown in Fig. 15, while Fig. 18 
illustrates an embodiment of the overall processing 
flow which is executed by the gateway 50 of the second 
embodiment shown in Fig. 15. 
5 The processing flow of Fig. 17 differs from that 

of Fig. 5 in the point of having step STa between 
steps ST8, ST9 and step ST10 in the processing flow 
of Fig. 5. Step STa executes such processing that the 
IP address of the server 40 is acquired by referring 

10 to the setting file 307 by the use of a search key 
which is a port number designated by the application 
program 300, and that the acquired IP address is 
written into the buffer 306. 

The processing flow of Fig. 18 and that of Fig. 

15 10 differ in that the former is executed by the 
gateway 50, whereas the latter is executed by the 
server 40. Besides, as an essential difference, the 
processing flow of Fig. 18 has step STa between steps 
ST7 and ST8 in the processing flow of Fig. 10. Step 

20 STa executes either the processing of receiving that 
IP address of the server 40 which has been sent in 
from the client 30, or the processing of acquiring 
that IP address of the server 40 which is not sent in 
from the client 30, in such a way that the setting 

25 file 506 is referred to using a search key which is 
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a port number notified by the client 30. 

As stated before, according to the present 
invention, the enhancement in the throughput of the 
end-to-end data communications is realized by adopting 
5 the contrivance that the resending control for 
guaranteeing data, which is performed in conformity 
with the protocol of the transport layer, is once 
terminated on this side of the radio channel . In 
order to implement the contrivance, the application 
10 program 300 issues the service request by designating 
the address "localhost" to function as the IP address 
of the corresponding apparatus itself, as explained 
before. 

For such a method of issuing the service request, 
15 according to the second embodiment shown in Fig. 15, 
the IP address required for the specification of the 
server 40 including the service program 400, the 
service of which is requested by the application 
program 300, is acquired using that setting file 307 
20 of the client 30 or that setting file 506 of the 
gateway 50 which manages the mapping relations between 
port numbers and IP addresses. 

According to the second embodiment shown in Fig. 
15, therefore, the apparatus is permitted to operate 
25 as the proxy which makes it seem as if the service 
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program 400 existed therein, to the application 
program 300. 

By the way, in a case where the setting file 307 
of the client 30 or the setting file 506 of the 
5 gateway 50 is not prepared, the service connected to 
the server 40 can be received using a host application 
protocol with a starting point set at the connected 
gateway 50 . 

Fig. 19 illustrates the resending processing of 

10 data transmission for use in the second embodiment of 
the present invention. 

In the resending processing, when the radio 
channel disconnected during the data transmission has 
been re-connected, data items are not transmitted 

15 again from the first data item, but data items are 
resent from the data item which was being transmitted 
at the time of the disconnection of the radio channel . 
Thus, efficient data transmission is realized. 

In order to implement the resending processing, 

20 concretely the format of data is so contrived that the 
sequence number (SN) of a packet is set in a header 
as indicated in Fig. 20. As illustrated in Fig. 19, 
when the radio channel disconnected during the data 
transmission has been re-connected, the sequence 

25 number ( SN = 2 in the illustrated example) the 
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transmission of which was completed last is notified 
(transmission of re-connecting SN), and the 
transmission of data items is thereafter restarted 
from the data item of the next sequence number (SN = 
5 3 in the illustrated example ) . 

By the way, in a case where the length of data 
in the format shown in Fig. 20 is greater than a 
length which can be transmitted at one time over the 
radio channel, the data is divided and then 

10 transmitted. In this case, the following measure 
should preferably be taken in order that a data part 
beginning with the header, which was sent till the 
disconnection of the radio channel, may not be wasted. 
That is, when the reception side transmits the 

15 re-connecting sequence number to the transmission side 
after the re-connection of the radio channel, it 
transmits a received length together. The 
transmission side is accordingly permitted to 
reconstruct the original data. 

20 The resending processing will be described in 

detail with reference to processing flows shown in 
Figs. 21 through 24. 

Here, Fig. 21 illustrates an embodiment of the 
processing flow which is executed by the transmission 

25 routine 302 of the client 30, Fig. 22 illustrates an 
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embodiment; of the processing flow which is executed 
by the reception routine 502 of the gateway 50, Fig. 
23 illustrates an embodiment of the processing flow 
which is executed by the transmission routine 503 of 
5 the gateway 50, and Fig. 24 illustrates an embodiment 
of the processing flow which is executed by the 
reception routine 303 of the client 30. 

As shown in the processing flow of Fig. 21, when 
the transmission routine 302 of the client 30 

10 transmits data to the gateway 50, it determines 
whether or not data is stored in the buffer 306. 
Subject to the determination that the data is stored, 
the transmission routine 302 reads the data out of the 
buffer 306 while affixing a sequence number thereto 

15 and transmits the resulting data toward the gateway 
50 through the radio channel. On this occasion, when 
the radio channel is disconnected, it is re-connected. 
Thereafter, the sequence number of data received last 
by the gateway 50, this sequence number being notified 

20 by the gateway 50, is received, and the transmission 
is restarted from data having a sequence number next 
to the notified sequence number. On the other hand, 
when the radio channel is not disconnected, the data 
transmitted from the buffer 306 to the gateway 50 is 

25 cleared, and the sequence number is incremented by "1" 
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(one), whereupon the processing flow returns to the 
first step. 

As shown in the processing flow of Fig. 22, in 
response to the transmission processing of the 
5 transmission routine 302 of the client 30, the 
reception routine 502 of the gateway 50 determines 
whether or not the radio channel is disconnected. 
When the disconnection of the radio channel has been 
determined, a re-connection timer is activated, 

10 followed by determining whether or not the radio 
channel has been re-connected within the set time 
period of the re-connection timer. Subject to the 
determination of the re-connection, the re-connection 
timer is stopped, and the sequence number of data 

15 received last is notified to the client 30. On the 
other hand, when the radio channel is not disconnected 
as the determination of the first step, data from the 
radio channel is received, and the received data is 
written into the reception buffer for merely 

20 delivering the data to the memory as explained before, 
whereupon the processing flow returns to the first 
step . 

Meanwhile, as shown in the processing flow of 
Fig. 23, when the transmission routine 503 of the 
25 gateway 50 sends data from the server 40, back to the 
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client 30, it determines whether or not data is stored 
in the buffer corresponding to the buffer 306 of the 
client 30. Subject to the determination that the data 
is stored, the transmission routine 503 reads the data 
5 out of the buffer while affixing a sequence number 
thereto and transmits the resulting data toward the 
client 30 through the radio channel. When the radio 
channel is disconnected on this occasion, it is 
re-connected on condition that a re-connection timer 

10 does not time over. After the re-connection, the 
re-connection timer is stopped. Subsequently, a 
sequence number received last as notified by the 
client 30 is received, and the transmission is 
restarted from data having a sequence number next to 

15 the notified sequence number. On the other hand, when 
the radio channel is not disconnected, the data 
transferred from the buffer is cleared, and the 
sequence number is incremented by "1" (one), whereupon 
the processing flow returns to the first step. 

20 As shown in the processing flow of Fig. 24, in 

response to the transmission processing of the 
transmission routine 503 of the gateway 50, the 
reception routine 303 of the client 30 determines 
whether or not data from the radio channel exists. 

25 Subject to the determination that the data exists, the 
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data is read out and is written into the reception 
buffer for merely delivering the data to the memory 
as explained before. Subsequently, whether or not the 
radio channel has been disconnected is determined. 
5 In case of the disconnection, the radio channel is 
re-connected. Thereafter, the sequence number of data 
received last is notified to the gateway 50. 

In this way, according to the resending 
processing shown in Fig. 19, after the radio channel 

10 disconnected during the data transmission has been 
re-connected, data items are not transmitted again 
from the first data item, but data items are resent 
from the data item which was being transmitted at the 
time of the disconnection of the radio channel. Thus, 

15 efficient data transmission is realized. 

Fig. 25 illustrates the architecture of an 
information system in the third embodiment of the 
present invention. Incidentally, although only one 
application program 300 is shown in the figure, 

20 actually a plurality of application programs may well 
be existent. 

As explained in the first embodiment shown in 
Fig. 3, the child processes 305 of the client 30 are 
respectively generated in correspondence with the 
25 session numbers which function as the identification 
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numbers of the individual application programs 300. 
Consequently, also the child processes 405 of the 
server 40 are respectively generated in correspondence 
with the session numbers which function as the 
5 identification numbers of the individual application 
programs 300 . 

As seen from the third embodiment shown in Fig. 
25, accordingly, the buffers 306 which are generated 
in correspondence with the child processes 305 of the 

10 client 30 are also respectively generated in 
correspondence with the session numbers which function 
as the identification numbers of the individual 
application programs 300. Reception buffers (not 
shown) for merely delivering data to a memory device 

15 as explained before, the reception buffers being 
included in the server 40, are also respectively 
generated in correspondence with the session numbers 
which function as the identification numbers of the 
individual application programs 300. 

20 The third embodiment shown in Fig. 25 is 

therefore contrived so as to realize an appropriate 
data transmission, in such a way that buffer control 
rules 308 which define a method of reading data out 
of the plurality of buffers 306 are stipulated on the 

25 side of the client 30 acting as a transmission side. 
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The buffer control rules 308 manage, for example, 
priority levels which are respectively allotted to the 
individual application programs 300. Thus, they 
command the transmission routine 302 to transmit data 
5 successively from the buffers 306 of higher priority 
levels. Alternatively, they command the transmission 
routine 302 to transmit data while setting the 
transmission cycles of the buffers 306 of higher 
priority levels shorter. 

10 Fig. 26 illustrates an embodiment of a processing 

flow which is executed by the transmission routine 302 
of the client 30 in the third embodiment. 

According to the third embodiment, as seen from 
the processing flow shown in Fig. 26, the transmission 

15 routine 302 of the client 30 reserves a buffer area 
on a memory and initializes the reserved area. Then, 
the transmission routine 302 sets rules for reading 
out the buffers 306, in compliance with a command 
given by the buffer control rules 308. Subsequently, 

20 the transmission routine 302 determines whether or not 
data is stored in one of the buffers 306. Subject to 
the determination that the data is stored, the 
transmission routine 302 waits until the data is 
permitted to be read out, and it reads the data out 

25 of the buffer 306 and transfers the read data to the 
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radio channel. When the radio channel is disconnected 
on this occasion, the data is resent after the 
re-connection of the radio channel. In contrast, when 
the radio channel is not disconnected, the data 
5 transferred from the buffer 306 is cleared, and the 
next buffer 306 designated by the buffer reading-out 
rules is thereafter set as a subject for transmission. 

On the other hand, when the server 40 acts as a 
transmission side, the transmission routine 403 
10 thereof executes a processing flow illustrated in Fig. 
27. 

As seen from the processing flow shown in Fig. 
27, the transmission routine 403 of the server 40 
reserves a buffer area on a memory and initializes the 

15 reserved area. Then, the transmission routine 403 
sets rules for reading out buffers (corresponding to 
the buffers 306 of the client 30), in compliance, with 
a command given by buffer control rules (not shown). 
Subsequently, the transmission routine 403 determines 

20 whether or not data is stored in one of the 
corresponding buffers. Subject to the determination 
that the data is stored, the transmission routine 403 
waits until the data is permitted to be read out, and 
it reads the data out of the buffer and transfers the 

25 read data to the radio channel. When the radio 
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channel is disconnected on this occasion, it is 
re-connected on condition that a re-connection timer 
does not time over. After the re-connection, the 
re-connection timer is stopped, and the data is 
5 resent. In contrast, when the radio channel is not 
disconnected, the data transferred from the buffer is 
cleared, and the next buffer designated by the buffer 
reading-out rules is thereafter set as a subject for 
transmission. 

10 According to the third embodiment shown in Fig. 

25, the data of the application programs 300 endowed 
with higher priority levels can be preferentially 
transmitted to the server 40. 

Fig. 28 illustrates the architecture of an 

15 information system in the fourth embodiment of the 
present invention. 

In addition to the various constituents of the 
second embodiment shown in Fig. 15, the fourth 
embodiment includes a data transfer control program 

20 309 which is installed in the client 30 acting as a 
data transmission side, and which monitors the data 
storing state of the buffer 306 and controls the 
transfer speed of data to be transferred from the 
application program 300 to the child process 305, on 

25 the basis of the monitored result. 
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If the memory capacity of the buffer 306 can be 
enlarged sufficiently, this buffer 306 does not 
overflow with data which are transferred from the 
child process 305. However, in a case where the 
5 enlargement of the memory capacity of the buffer 306 
is restricted, this buffer 306 overflows with the data 
which are transferred from the child process 305 . The 
fourth embodiment shown in Fig. 28 is furnished with 
the data transfer control program 309 in order to 
10 eliminate such a drawback. 

Fig. 29 illustrates embodiments of a processing 
flow which is executed by the data transfer control 
program 309 . 

As seen from the processing flow shown at (a) in 
15 Fig. 29, when the application program 300 is 
activated, the data transfer control program 309 
starts processing so as to determine whether or not 
data stored in the buffer 306 has exceeded a threshold 
value. Subject to the determination that the 
20 threshold value has been exceeded, the control program 
309 calculates a delay time for issuing an ACK 
( reception acknowledgement ) in socket communications , 
from the remaining capacity of the buffer 306. 
Further, the control program 309 commands the child 
25 process 305 to issue the ACK to the application 
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program 300 in accordance with the calculated delay 
time. Thus, the data transfer speed of the socket 
communications of virtual circuit type between the 
application program 300 and the child process 305 is 
5 controlled so as to become lower. 

Alternatively, as seen from the processing flow 
shown at (b) in Fig. 29, when the application program 
300 is activated, the data transfer control program 
309 starts processing so as to determine whether or 

10 not data stored in the buffer 306 has exceeded a 
threshold value. Subject to the determination that 
the threshold value has been exceeded, the control 
program 309 calculates a window size (the size of data 
which the application program 300 can transfer without 

15 waiting an ACK) from the remaining capacity of the 
buffer 306. Further, the control program 309 commands 
the application program 300 to transfer the data in 
accordance with the window size. Thus, the data 
transfer speed of the communications of virtual 

20 circuit type is controlled so as to become lower. 

In this way, according to the fourth embodiment 
shown in Fig. 28, even when the memory capacity of the 
buffer 306 cannot be enlarged, the transmission of 
data can be controlled so that the buffer 306 may not 

25 overflow with data. 
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Although the data transfer control program 309 
is installed in the client 30 in the fourth embodiment 
of Fig. 28, actually a similar data transfer control 
program (Z in Fig. 30) will be often installed on the 
5 side of the gateway 50 which sends data back to the 
client 30, as in the fifth embodiment illustrated in 
Fig. 30. Incidentally, a child process X shown in 
Fig. 30 is generated when the gateway 50 acts as a 
transmission side, while a buffer Y is generated when 

10 the gateway 50 acts as the transmission side. In this 
case, the data transfer control program Z commands the 
child process X to issue an ACK to the service program 
400 of the server 40 in accordance with a designated 
delay time, or it commands the service program 400 to 

15 transfer data to the buffer Y in accordance with a 
designated window size. Thus, the data transfer speed 
of the virtual circuit type communications between the 
service program 400 and the child process X is 
controlled so as to become lower. 

20 Figs. 31 and 32 illustrate the sixth and seventh 

embodiments of the present invention, respectively. 

In addition to the various constituents of the 
second embodiment shown in Fig. 15, the sixth 
embodiment shown in Fig. 31 includes a cache memory 

25 310 which is installed in the client 30, and which 
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stores therein the mapping relations between data 
items obtained from the server 40 and request messages 
for the data items. Thus, in a case where a data 
request message issued by the application program 300 
5 designates data registered in the cache memory 310, 
the child process 305 in the client 30 can notify the 
pertinent data in the cache memory 310, to the 
application program 300 without the access of the 
client 30 to the server 40. 

10 Further, in addition to the various constituents 

of the second embodiment shown in Fig. 15, the seventh 
embodiment shown in Fig. 32 includes a cache memory 
507 which is installed in the gateway 50, and which 
stores therein the mapping relations between data 

15 items obtained from the server 40 and request messages 
for the data items. Thus, in a case where a data 
request message issued by the application program 300 
designates data registered in the cache memory 507, 
the child process 505 in the gateway 50 can read the 

20 pertinent data out of the cache memory 507 and notify 
the read data to the application program 300 without 
the access of the gateway 50 to the server 40. 

According to the sixth or seventh embodiment, 
traffic on the network such as the radio channel or 

25 the Internet 60 can be relieved. 
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Consequently, according to the sixth or seventh 
embodiment, the throughput of the data communications 
between the client 30 and the server 40 can be 
enhanced in a case where, using the radio channel, the 
5 client 30 accesses an information system as shown in 
Fig. 33, which is constructed by connecting the server 
40 and the gateway 50 to the Internet 60 and also 
connecting this gateway 50 and the base station 80 of 
a radio communication network to a public network 70. 

10 Although the present invention has been described 

above in detail in conjunction with the illustrated 
embodiments, it is not restricted thereto. By way of 
example, the protocols TCP and IP have been mentioned 
as concrete examples in the embodiments, but the 

15 present invention is directly applicable to cases of 
employing protocols which are different from the TCP 
and IP and which perform the resending control of data 
in a transport layer. 
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What is claimed is: 

1 . An apparatus for use in a radio communication 
system wherein the apparatus communicates with another 
5 apparatus through a radio channel, comprising: 

monitoring means for monitoring whether or 
not a transmission request for data, designating the 
particular apparatus itself as a transmission 
destination, has been issued by said particular 
10 apparatus or the other apparatus connected thereto 
through a network; 

generation means for generating a process to 
serve as a reception destination for the data and 
generating a buffer in correspondence with the 
15 process, when said monitoring means has detected the 
issue of the transmission request; 

transfer means for transferring the data from 
a transmission request source to said process in 
accordance with communications of virtual circuit 
20 type, so as to store in the buffer the data 
transmitted by the transmission request source; and 

transmission means for transmitting the data 
stored in said buffer, to said other apparatus through 
the radio channel . 

25 
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2. An apparatus for use in a radio communication 
system as defined in claim 1, wherein said 
transmission means transmits transmission destination 
information to be designated, in accordance with a 

5 protocol of an upper layer with respect to layers of 
said radio channel. 

3 . An apparatus for use in a radio communication 
system as defined in claim 1, further comprising: 

10 detection means for detecting a data storing 

state of said buffer; 

wherein said transfer means controls a 
communication speed of the virtual circuit type 
communications in accordance with a detected result 

15 of said detection means. 

4. An apparatus for use in a radio communication 
system as defined in claim 2, further comprising: 

detection means for detecting a data storing 
20 state of said buffer; 

wherein said transfer means controls a 
communication speed of the virtual circuit type 
communications in accordance with a detected result 
of said detection means. 
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5. An apparatus for use in a radio communication 
system as defined in claim 1, further comprising: 

specification means for specifying a sequence 
number of the transmission data at a point of time of 
5 the disconnection, when said radio channel has been 
disconnected ; 

wherein said transmission means restarts the 
data transmission from said data of the sequence 
number specified by said specification means, when 
10 said radio channel has been re-connected. 

6 . An apparatus for use in a radio communication 
system as defined in claim 2, further comprising: 

specification means for specifying a sequence 
15 number of the transmission data at a point of time of 
the disconnection, when said radio channel has been 
disconnected ; 

wherein said transmission means restarts the 
data transmission from said data of the sequence 
20 number specified by said specification means, when 
said radio channel has been re-connected. 

7. An apparatus for use in a radio communication 
system as defined in claim 3, further comprising: 

25 specification means for specifying a sequence 
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number of "the transmission data at a point of time of 
the disconnection, when said radio channel has been 
disconnected; 

wherein said transmission means restarts the 
5 data transmission from said data of the sequence 
number specified by said specification means, when 
said radio channel has been re-connected. 



8. An apparatus for use in a radio communication 
10 system as defined in claim 4, further comprising: 

specification means for specifying a sequence 
number of the transmission data at a point of time of 
the disconnection, when said radio channel has been 
disconnected ; 

15 wherein said transmission means restarts the 

data transmission from said data of the sequence 
number specified by said specification means, when 
said radio channel has been re-connected. 



20 9 . An apparatus for use in a radio communication 

system as defined in claim 1, wherein when a plurality 
of such buffers are generated by said generation 
means, said transmission means reads out data 
successively from the buffers of higher priority 

25 levels in accordance with priority levels set for the 
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respec-tive buffers and transmits the read data. 

10. An apparatus for use in a radio 
communication system as defined in claim 1, wherein 

5 when a plurality of such buffers are generated by said 
generation means, said transmission means transmits 
data while setting transmission cycles of the data 
stored in the buffers of higher priority levels, 
shorter in accordance with priority levels set for the 
10 respective buffers. 

11. An apparatus for use in a radio 
communication system as defined in claim 1, further 
comprising: 

15 a cache memory which stores therein data 

sent back in response to the data transmission of said 
transmission means; and 

search means for searching as to whether or 
not data requested by said transmission request source 

20 is registered in said cache memory; 

wherein when the registration of the 
requested data in said cache memory has been detected 
by said search means, said process transfers said 
requested data in said cache memory, to said 

25 transmission request source through said transfer 
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means . 

12. An apparatus for use in a radio 
communication system wherein the apparatus 

5 communicates with another apparatus through a radio 
channel, comprising: 

reception means for receiving data sent in 
through the radio channel; 

monitoring means for monitoring whether or 
10 not said reception means has received data which 
conforms to a protocol suspended in layers of said 
radio channel; 

generation means for generating a process 
to serve as a reception destination for the data, when 
15 said monitoring means has detected the reception of 
the pertinent data; and 

transfer means for transferring the data 
received by the process, to a transmission request 
destination in accordance with communications of 
20 virtual circuit type. 

13. An apparatus for use in a radio 
communication system as defined in claim 12, further 
comprising: 

25 a cache memory which stores therein data 
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sent back from -the -transmission request destination 
in response to the data transfer of said transfer 
means ; and 

search means for searching as to whether or 
5 not data requested by the data sent in through said 
radio channel is registered in said cache memory; and 
transmission means for transmitting said 
requested data in said cache memory, to said 
transmission request source through said radio 
10 channel, when the registration of the requested data 
in said cache memory has been detected by said search 
means . 

14. A program recording medium storing therein 
15 programs which are employed for incarnating an 
apparatus for use in a radio communication system 
wherein the apparatus communicates with another 
apparatus through a radio channel, the programs 
causing a computer to execute processing comprising 
20 the steps of: 

monitoring whether or not a transmission 
request for data, which designates the particular 
apparatus itself as a transmission destination, has 
been issued by said particular apparatus or the other 
25 apparatus connected thereto through a network; 
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generating a process to serve as a reception 
destination for the data and also generating a buffer 
in correspondence with the process, when the 
monitoring step has detected the issue of the 
5 transmission request; 

transferring the data from a transmission 
request source to said process in accordance with 
communications of virtual circuit type, so as to store 
in the buffer the data transmitted by the transmission 
10 request source; and 

transmitting the data stored in said buffer, 
to said other apparatus through the radio channel. 

15. A program recording medium storing therein 
15 programs which are employed for incarnating an 
apparatus for use in a radio communication system 
wherein the apparatus communicates with another 
apparatus through a radio channel, the programs 
causing a computer to execute processing comprising 
20 the steps of: 

receiving data sent in through the radio 

channel ; 

monitoring whether or not the receiving step 
has received data which conforms to a protocol 
25 suspended in layers of said radio channel; 
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generating a process to serve as a reception 
destination for the data, when the monitoring step has 
detected the reception of the pertinent data; and 

transferring the data received by the 
5 process, to a transmission request destination in 
accordance with communications of virtual circuit 
type. 

16. A data communication method for a radio 
10 communication system wherein apparatuses communicate 
through a radio channel, comprising the steps of: 

(a) monitoring if a transmission request for 
data, which designates a particular one of the 
apparatuses as a transmission destination, has been 

15 issued by the particular apparatus or another of said 
apparatuses connected thereto through a network; 

(b) generating a process to serve as a 
reception destination for the data and also generating 
a buffer in correspondence with the process, when the 

20 issue of the transmission request has detected; 

(c) transferring the data from a 
transmission request source to said process in 
accordance with communications of virtual circuit 
type, so as to store in the buffer the data 

25 transmitted by the transmission request source; and 
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(d) transmitting the data stored in said 
buffer, to said other apparatus through the radio 
channel . 



5 17. A data communication method as defined in 

Claim 16, wherein in step (d), transmission 
destination information to be designated is 
transmitted in accordance with a protocol of an upper 
layer with respect to layers of said radio channel. 

10 

18. A data communication method as defined in 
Claim 16, further comprising the step of: 

(e) detecting a data storing state of said 

buffer; 

15 wherein in step (c), a communication speed 

of the virtual circuit type communications is 
controlled in accordance with a result of the 
detection. 



20 19. A data communication method as defined in 

Claim 16, further comprising the step of: 

(f) specifying a sequence number of the 
transmission data at a point of time of disconnection 
when said radio channel has been disconnected; 

25 wherein in step (d), the data transmission 
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is restarted from the data of the specified sequence 
number when said radio channel has been re-connected. 

20. A data communication method as defined in 
5 claim 16, wherein when a plurality of such buffers 

have been generated in step (b), step (d) operates to 
read out data successively from the buffers of higher 
priority levels in accordance with priority levels set 
for the respective buffers, and to transmit the read 
10 data. 

21. A data communication method as defined in 
claim 16, wherein when a plurality of such buffers 
have been generated in step (b), step (d) operates to 

15 transmit data stored in the respective buffers while 
setting transmission cycles of the data stored in said 
buffers of higher priority levels, shorter in 
accordance with priority levels set for said 
respective buffers. 

20 

22. A data communication method as defined in 
claim 16, further comprising the steps of: 

(g) storing data sent back in response to 
the data transmission of step ( d ) , in a cache memory; 
25 (h) making a search as to whether data 
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requested by said transmission request source is 
stored in the cache memory; and 

( i ) reading the requested data out of said 
cache memory and transmitting the read data to said 
5 transmission request source, when the data requested 
by said transmission request source is stored in the 
cache memory. 

23 . A data communication method for a radio 
10 communication system wherein apparatuses communicate 
through a radio channel, comprising the steps of: 

(a) receiving data sent in through the radio 

channel ; 

(b) monitoring whether or not the received 
15 data conforms to a protocol suspended in layers of 

said radio channel; 

(c) generating a process to serve as a 
reception destination for the data, when the reception 
of the data conforming to the protocol has been 

20 detected; and 

(d) transferring the data received by the 
process, to a transmission request destination in 
accordance with communications of virtual circuit 
type. 



25 
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24. A data communication method as defined in 
claim 23, further comprising the steps of: 

(e) storing data sent back from the 
transmission request destination in response to the 

5 data transfer, in a cache memory; 

( f ) making a search as to whether or not 
data requested by the data received through said radio 
channel is registered in the cache memory; and 

(g) transmitting the requested data in said 
10 cache memory, to said transmission request source 

through said radio channel when said requested data 
is registered in said cache memory. 

25. A data communication method for a radio 
15 communication system wherein apparatuses communicate 

through a radio channel , comprising the steps of : 

(a) transmitting data requested by a 
transmission source, in accordance with communications 
of virtual circuit type by employing a protocol of an 

20 upper layer with respect to layers of the radio 
channel ; 

(b) transmitting the data transmitted by 
employing the protocol of the upper layer, through 
said radio channel by employing a protocol of the 

25 layers of said radio channel; and 
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(c) transmitting the data transmitted by 
employing said protocol of said layers of said radio 
channel, to a transmission request destination in 
accordance with the virtual circuit type 
5 communications by employing said protocol of said 
upper layer with respect to said layers of said radio 
channel . 

26. A radio communication system wherein 
10 different apparatuses communicate through a radio 
channel, comprising: 

a first apparatus comprising: 

first communication means for receiving 
data which is to be transmitted from a transmission 
15 request source within a particular one of the 
different apparatuses to a transmission request 
destination within another of said different 
apparatuses in accordance with communications of 
virtual circuit type by employing a protocol of an 
20 upper layer with respect to layers of the radio 
channel ; and 

first radio communication means for 
transmitting data inputted from said first 
communication means to the other apparatus through 
25 said radio channel in accordance with a protocol of 
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the layers of said radio channel; and 

a second apparatus comprising: 

second radio communication means for 
receiving the data transmitted in from said first 
5 radio communication means through said radio channel 
in accordance with the protocol of said layers of said 
radio channel; and 

second communication means for 
transmitting the data received by said second radio 
10 communication means, to the transmission request 
destination within the particular apparatus in 
accordance with the virtual circuit type 
communications by employing the protocol of the upper 
layer with respect to said layers of said radio 
15 channel. 



27. A radio communication system, comprising: 
a client comprising: 

first inter-process communication means 
20 for transmitting and receiving data which are 
exchanged between said client and a server, by 
communications of virtual circuit type in conformity 
with a protocol of an upper layer with respect to 
layers of a radio channel; and 
25 first radio communication means for 
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transmitting and receiving the data which are 
exchanged between said client and said server and 
which are inputted to and outputted from said first 
inter-process communication means, between said first 
5 radio communication means and said server through said 
radio channel in conformity with a protocol of the 
layers of said radio channel; 

a gateway comprising: 

second radio communication means for 

10 transmitting and receiving said data which are 
exchanged between said client and said server, between 
said second radio communication means and said first 
radio communication means through said radio channel 
in conformity with the protocol of said layers of said 

15 radio channel; and 

second inter-process communication 
means for transmitting and receiving said data which 
are exchanged between said client and said server, 
between said second inter-process communication means 

20 and said server through said Internet by the virtual 
circuit type communications in conformity with the 
protocol of the upper layer with respect to said 
layers of said radio channel; and 
a server comprising: 

25 third inter-process communication means 
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for transmitting and receiving said data which are 
exchanged between said client and said server, between 
said third inter-process communication means and said 
gateway through said Internet in conformity with said 
5 protocol of said upper layer with respect to said 
layers of said radio channel; 

wherein said client and said gateway are 
connected through said radio channel, and said gateway 
and said server are connected through said Internet. 

.0 

28. A radio communication system as defined in 
claim 27, wherein said client and said gateway are 
communicatively connected through a public network and 
a radio communication network. 
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Abstract of the Disclosure 



An apparatus for use in a radio communication 
system, comprising a monitoring unit which monitors 
5 whether or not a transmission request for data, 
designating the particular apparatus itself as a 
transmission destination, has been issued by the 
particular apparatus or another apparatus connected 
thereto through a network; a generation unit which 

10 operates when the monitoring unit has detected the 
issue of the transmission request, to generate a 
process to serve as a reception destination for the 
data and also to generate a buffer in correspondence 
with the process; a transfer unit which transfers the 

15 data from a transmission request source to the process 
in accordance with communications of virtual circuit 
type, so as to store the data in the buffer; and a 
transmission unit which transmits the data stored in 
the buffer, to the other apparatus through a radio 

20 channel. Thus, enhancement in the throughput of 
end-to-end data communications can be realized. 
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